package com.whjz.dcfs.pub.excel;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 属性定义注解，用于Excel导入
 * 可以按照pos定位或name匹配,两者都有值则会验证该列的标题是否与配置name一致
 */
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelColumn {
    /**
     * 对于Excel文件中的列，列索引以0开始
     *
     * @return
     */
    int pos() default -1;

    /**
     * Excel中列对应的数据类型
     *
     * @return
     */
    Class propType() default String.class;

    /**
     * 日期格式使用,可支持多格式,以逗号分隔
     *
     * @return
     */
    String format() default "yyyy-MM-dd,yyyy/MM/dd,yyyyMMdd";

    /**
     * 列的中文名称
     *
     * @return
     */
    String name() default "";

    /**
     * 是否非空
     *
     * @return
     */
    boolean required() default false;

}
